## **EE2000 Logic Circuit Design**

## Lecture 8-VHDL 2



## Encoder (Decimal-to-BCD Encoder)

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
                                                                                  A_0 (LSB)
                                                                                            OUTO
use IEEE.STD LOGIC UNSIGNED.ALL;
entity ENC3 is
   Port ( Q : in std logic;
                                                                                            OUT1
         R : in std logic;
          S : in std logic;
         T : in std logic;
                                                                                            OUT2
         U : in std logic;
         V : in std logic;
         W : in std logic;
                                                                                  A_3 (MSB)
         X : in std logic;
         Y : in std logic;
         Z : in std logic;
         OUTO : out std logic;
                                                          R OR T OR V OR X OR Z;
         OUT1 : out std logic;
         OUT2 : out std logic;
                                             OUT1 <= S OR T OR W OR X;
         OUT3 : out std logic);
end ENC3:
                                             OUT2 <= U OR V OR W OR X;
architecture Behavioral of ENC3 is
                                             OUT3 <= Y OR Z;
begin
          process (Q,R,S,T,U,V,W,X,Y,Z)
          begin
```

**Enter your codes here** 

```
end process;
end Behavioral:
```

## T-Flip Flop with RESET

Rising edge FF Asyn Active High Reset

| С | T | $Q_{t+1}$        | $\overline{Q_{t+1}}$ | State  |
|---|---|------------------|----------------------|--------|
| 0 | Х | $Q_t$            | $\overline{Q_t}$     | Hold   |
| 1 | 0 | $Q_t$            | $\overline{Q_t}$     | Hold   |
| 1 | 1 | $\overline{Q_t}$ | $Q_t$                | Toggle |

```
architecture behavioral of TFF is
signal tmp : std logic;
begin
process(clk, areset)
begin
 if areset = '1' then
   TMP <= '0';
 elsif rising edge(clk) then
   if (T = 1) then
     TMP <= not TMP;
   end if:
 end if;
\bigcirc <= TMP;
end process;
end behavioral;
```